CLAIMS 

1 LA graph walking system, comprising: 

2 a binding system for binding a graph observer with a data graph, for binding node 

3 patterns to node observers to generate at least one node pattern/node observer pair, and for 

4 binding the data graph observer to at least one node pattern/node observer pairing, and wherein 

|5 each node pattern includes a computed set of target sub-node patterns; 

Q 

(g a node relationship graph (NRG), wherein each node in the NRG corresponds to at least 

W 

*D one node in the data graph, and wherein each node in the NRG includes a computed set of valid 

M 

1 $ sub-node patterns; 

m 



graph walking logic for systematically walking through nodes in the data graph and 
corresponding nodes in the NRG; and 

a pattern testing system that determines if the set of target sub-node patterns for a node 

12 pattern matches the set of valid sub-node patterns for a corresponding NRG node when a node is 

1 3 encountered in the data graph. 

1 2. The graph walking system of claim 1, wherein the set of target sub-node patterns includes at 

2 least one generational node pattern. 

~1 3:~The^ph~waMng"syst^~of c 

2 deactivating a graph observer for sub-node processing when no matches occur between target 

3 sub-node patterns and valid sub-node patterns for an encountered node. 
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1 4. The graph walking system of claim 3, wherein the graph walking logic includes a sub-node 

2 pruning system for disabling the graph walking logic when all graph observers for a set of sub- 

3 node have been deactivated. 

1 5. The graph walking system of claim 1, wherein the graph walking logic stores a list of node 

2 pattern/node observer pairs corresponding to matches made by the pattern testing system for 

3 each node. 

b 

% 6. The graph walking system of claim 5, wherein, for a root node, the pattern testing system tests 

fi2 each target sub-node pattern for all node patterns bound the graph observer, and adds a 

s « 

2 : : 

s-3 corresponding node pattern/node observer pair to the list of corresponding node pattern/node 

Q- observer pairs for the root node. 

nj 

- 

: "— t 

"1 7. The graph walking system of claim 5, wherein, for a child node, the pattern testing system 

2 tests each target sub-node pattern associated with the list of node pattern/node observer pairs 

3 stored for a parent node. 

1 8. The graph walking system of claim 7, wherein the pattern testing system adds a 

2 corresponding node pattern/node observer pair to the list of corresponding node pattern/node 

3 observer pairs for the child node when a match occurs. "■ 
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1 9. A system for optimizing a graph walking process of an inputted data graph based on inputted 

2 node patterns and a node relationship graph (NRG) that corresponds to the inputted data graph, 

3 the system comprising: 

4 a system for generating a set of valid sub-node patterns for each node in the NRG; 

5 a system for generating a set of target sub-node patterns for each inputted node pattern; 

6 a graph processor for systematically walking through nodes within the data graph and 

7 corresponding nodes in the NRG; and 

ll a pattern testing system that determines if the target sub-node patterns for a node pattern 

*Jj match the valid sub-node patterns for a corresponding node in the NRG when a node is 

isj 
rt. 5 

Ifl encountered in the data graph. 

m 

□ 10. The system of claim 9, further comprising a first pruning system that can be instructed by a 

CS node observer bound with an associated graph observer to deactivate the associated graph 

^3 observer for a set of sub-nodes when no matches occur between target sub-node patterns and 

4 valid sub-node patterns. 

1 11. The system of claim 10, further comprising a second pruning system that can instruct the 

2 graph processor not to walk the set of sub-nodes if all graph observers have been deactivated. 

1 1 2 . "The system of claim"9, "wherein the graph processor includes a root node test, wherein the - 

2 root node test tests all target sub-node patterns. 
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1 13. The system of claim 9, wherein the graph processor includes a child node test, wherein the 

2 child node test tests only target sub-node patterns associated with node patterns that had at least 

3 one match in a parent node. 
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1 14. A method for analyzing a graph of hierarchical data, comprising the steps of: 

2 binding a plurality of graph observers to the graph, wherein each graph observer is 

3 further bound to a set of inputted node patterns and a set of inputted node observers; 

4 computing a set of target sub-node patterns for each inputted node pattern; 

5 providing a node relationship graph (NRG) for the graph, wherein each node in the NRG 

6 corresponds to a node in the graph; 

7 computing a set of valid sub-node patterns for each node in the NRG; 
C| systematically walking through nodes within the graph; 

x % testing to determine if the target sub-node patterns for a node pattern matches the valid 

Tsar 

lj§ sub-node patterns for a corresponding NRG node when a node is encountered in the graph; and 

In 

i\ deactivating an identified graph observer for sub-nodes of an encountered node if none of 

© the target sub-node patterns associated with node patterns bound to the identified graph observer 

83 match valid sub-node patterns. 

n 

1 15. The method of claim 14, comprising the further step of reactivating the identified graph 

2 observer after the sub-nodes of the encountered node have been walked. 
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1 16. A program product stored on a recordable medium, which when executed, optimizes a graph 

2 walking process of an inputted data graph based on inputted node patterns and a node 

3 relationship graph (NRG) that corresponds to the inputted data graph, the program product 

4 comprising: 

5 means for generating a set of valid sub-node patterns for each node in the NRG; 

6 means for generating a set of target sub-node patterns for each inputted node pattern; 

7 means for systematically walking through nodes within the data graph and corresponding 
fg nodes in the NRG; and 

W means for determining if the target sub-node patterns for a node pattern match the valid 

IS sub-node patterns for a corresponding node in the NRG when a node is encountered in the data 

Yt graph. 

Q 

m 

ijk 17. The program product of claim 16, further comprising a first pruning system that can be 

l€ instructed by a node observer bound with an associated graph observer to deactivate the 

3 associated graph observer for a set of sub-nodes when no matches occur between target sub-node 

4 patterns and valid sub-node patterns. 

1 18. The program product of claim 17, further comprising a second pruning system that can 

2 instruct the graph processor not to walk the set of sub-nodes if all graph observers have been 
3 deactivated? 
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1 19. The program product of claim 16, wherein the determining means includes a root node test, 

2 wherein the root node test tests all target sub-node patterns. 

1 20. The program product of claim 16, wherein the determining means includes a child node test, 

2 wherein the child node test tests only target sub-node patterns associated with node patterns that 

3 had at least one match in a parent node. 
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